<template>
  <van-list v-model="loading" :finished="finished" finished-text="没有更多了" @load="onLoad" :immediate-check="false">
    <!-- <van-cell v-for="(item,index) in list" :key="index" :title="item.content" /> -->
    <comment-item 
    v-for="(item, index) in list" 
    :key="index" 
    :comment="item" 
    @reply-click="$emit('reply-click',$event)"/>
  </van-list>
</template>

<script>
import { getComments } from '@/api/comment.js'
import CommentItem from './comment-item'
export default {
  name: '',
  components: {
    'comment-item': CommentItem,
  },
  props: {
    source: {
      type: [Number, String, Object],
      required: true,
    },
    list:{
      type:Array,
      default:()=>[]
    },
    type:{
      type:String,
      validator:(data)=>{
        return ['a','c'].includes(data)
      },
      default:'a'
    }
  },
  data() {
    return {
      // list: [],
      loading: false,
      finished: false,
      offset: null, // 请求下一页数据的页码
      totalCount: 0, // 总数据条数
    }
  },
  methods: {
    async onLoad() {
      // 异步更新数据
      try {
        const { data } = await getComments({
          type: this.type, // 评论类型，a-对文章(article)的评论，c-对评论(comment)的回复
          source: this.source.toString(), // 源id，文章id或评论id
          offset: this.offset, // 获取评论数据的偏移量，值为评论id，表示从此id的数据向后取，不传表示从第一页开始读取数据
          limit: 10, // 每页大小
        })

        console.log(data)

        // 2. 将数据添加到列表中
        const { results } = data.data
        this.list.push(...results)

        // 更新总数据条数
        // this.totalCount = data.data.total_count
        this.$emit('onload-success', data.data.total_count)
        // 3. 将加载更多的 loading 设置为 false
        this.loading = false

        // 4. 判断是否还有数据
        if (results.length) {
          this.offset = data.data.last_id // 更新获取下一页数据的页码
        } else {
          this.finished = true // 没有数据了，关闭加载更多
        }
      } catch (err) {
        console.log(err);
      }
    },
  },
  created() {
    this.loading = true
    this.onLoad()
  },
}
</script>

<style lang="" scoped>
</style>